package com.ygqh.baby.mapper;

import com.ygqh.baby.ao.ProductStatus;
import com.ygqh.baby.ao.QueryInfo;
import com.ygqh.baby.model.ProductPackQueryRequest;
import com.ygqh.baby.model.YgProductPackExt;
import com.ygqh.baby.model.YgProductPackModel;
import com.ygqh.baby.po.YgProduct;
import com.ygqh.baby.po.YgProductPack;
import org.apache.ibatis.annotations.Param;

import java.util.Date;
import java.util.List;

/**
 * @author guohao
 */
public interface YgProductPackV2Mapper {

    /**
     * 检索数量
     *
     * @param queryRequest 检索条件
     * @return int
     */
    int countSuperV2(ProductPackQueryRequest queryRequest);

    /**
     * 查询
     *
     * @param queryRequest 检索条件
     * @return List<YgProductPackExt>
     */
    List<YgProductPackExt> selectSuperV2(ProductPackQueryRequest queryRequest);

    /**
     * 获取商品列表并标记已参与自选包商品
     *
     * @param queryInfo     分页
     * @param productName   商品名称
     * @param groupId       分组id
     * @param productStatus 商品状态
     * @param supplierId    商家id
     * @param packId        自选包id
     * @return List<YgProduct>
     */
    List<YgProduct> selectProductListWithPackSign(@Param("queryInfo") QueryInfo queryInfo, @Param("productName") String productName,
                                                  @Param("groupId") Long groupId, @Param("productStatus") ProductStatus productStatus,
                                                  @Param("supplierId") Long supplierId, @Param("packId") Long packId);

    /**
     * 获取自选包详情
     *
     * @param packId 自选包id
     * @return YgProductPackExt
     */
    YgProductPackExt getProductPackInfo(@Param("packId") Long packId);

    /**
     * 获取自选包列表
     *
     * @param productId 商品id
     * @return List<YgProductPackModel>
     */
    List<YgProductPackModel> selectPackList(@Param("productId") Long productId, @Param("currentDate") Date currentDate);

    List<Long> findProductIdsByPackId(Long packId);

    List<YgProductPack> selectByUpdateTime(@Param("startTime") Date startTime, @Param("endTime") Date endTime);

    /**
     * 根据productIds获取自选包列表
     *
     * @param pStatus    PromotionStatus
     * @param date       当前时间
     * @param productIds 商品id
     * @return List<YgProductPack>
     */
    List<YgProductPack> selectPackListByProductIds(@Param("pStatus") String pStatus, @Param("currentDate") Date date, @Param("productIds") Long... productIds);
}
